package personal.zq.practice.common.utils.leetcode.medium;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;

/**
 * 汽水瓶
 * 时间限制：C/C++ 1秒，其他语言2秒
 * <p>
 * 空间限制：C/C++ 32M，其他语言64M
 * <p>
 * 某商店规定：三个空汽水瓶可以换一瓶汽水，允许向老板借空汽水瓶（但是必须要归还）。
 * 小张手上有n个空汽水瓶，她想知道自己最多可以喝到多少瓶汽水。
 * 数据范围：输入的正整数满足
 * <p>
 * 注意：本题存在多组输入。输入的 0 表示输入结束，并不用输出结果。
 * <p>
 * 输入描述:
 * 输入文件最多包含 10 组测试数据，每个数据占一行，仅包含一个正整数 n（ 1<=n<=100 ），表示小张手上的空汽水瓶数。n=0 表示输入结束，你的程序不应当处理这一行。
 * <p>
 * <p>
 * 输出描述:
 * 对于每组测试数据，输出一行，表示最多可以喝的汽水瓶数。如果一瓶也喝不到，输出0。
 * <p>
 * <p>
 * 输入例子1:
 * 3
 * 10
 * 81
 * 0
 * <p>
 * 输出例子1:
 * 1
 * 5
 * 40
 * <p>
 * 例子说明1:
 * 样例 1 解释：用三个空瓶换一瓶汽水，剩一个空瓶无法继续交换
 * 样例 2 解释：用九个空瓶换三瓶汽水，剩四个空瓶再用三个空瓶换一瓶汽水，剩两个空瓶，向老板借一个空瓶再用三个空瓶换一瓶汽水喝完得一个空瓶还给老板
 *
 * @author zhangqing
 * @version 1.0
 * @date 2022/7/29
 */
public class SodaButters {

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String str = null;
        ArrayList<Integer> a = new ArrayList<Integer>();
        for (int i = 0; i < 10; i++) {
            int n = Integer.parseInt(br.readLine());
            if (n == 0) {
                break;
            }
            if (n < 2) {
                System.out.println("0");
            } else {
                a.add(revert(n));

            }
        }
        for (Integer k : a) {
            System.out.println(k);
        }
    }

    public static int revert(int n) {
        int resp = 0;
        if (n < 2) {
            return resp;
        }
        boolean f = false;
        if (n == 2) {
            n = n + 1;
            f = true;
        }
        int m = n / 3;
        int j = n % 3;
        int k = m + j;
        if (f) {
            k = k - 1;
        }
        resp = m + revert(k);
        return resp;
    }
}
